package br.com.minhasfinancas.api.model;

import java.util.List;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.validation.constraints.NotNull;

import org.hibernate.annotations.ForeignKey;

import br.com.minhasfinancas.fw.model.AbstractModel;

@Entity
public class Conta extends AbstractModel<Long> {
	private static final long serialVersionUID = 1L;
	
	@Id @GeneratedValue(strategy=GenerationType.SEQUENCE)
	@Column(name = "ID_CONTA")
	private Long id;
	
	@NotNull
	@Column(name = "TITULO", length = 45)
	private String titulo;
	
	@NotNull
	@Column(name = "SALDO")
	private double saldo;
	
	@OneToMany(mappedBy="conta", fetch = FetchType.LAZY)
	private List<Receita> receitas;
	
	@OneToMany(mappedBy="conta", fetch = FetchType.LAZY)
	private List<Despesa> despesas;
	
	@JoinColumn(name = "ID_USUARIO")
	@ManyToOne
	@ForeignKey(name = "FK_USUARIO_CONTA")
	private Usuario usuario;
	
	public Conta(){
	}

	@Override
	public Long getId() {
		return this.id;
	}
	
	@Override
	public void setId(Long id) {
		this.id = id;
		
	}

	public Usuario getUsuario() {
		return usuario;
	}

	public void setUsuario(Usuario usuario) {
		this.usuario = usuario;
	}
	
	public String getTitulo() {
		return titulo;
	}

	public void setTitulo(String titulo) {
		this.titulo = titulo;
	}
	
	public double getSaldo() {
		return saldo;
	}
	
	public void setSaldo(double saldo) {
		this.saldo = saldo;
	}

	public List<Receita> getReceitas() {
		return receitas;
	}

	public void setReceitas(List<Receita> receitas) {
		this.receitas = receitas;
	}
	
}
